-
Notifications
You must be signed in to change notification settings - Fork 147
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Try to reopen database in case of unexpected closure #175
base: main
Are you sure you want to change the base?
Try to reopen database in case of unexpected closure #175
Conversation
@jakearchibald can you merge this PR ? Thx |
Thanks for the ping. I'll take a look. |
Implemented this yesterday for our app and seems to have mitigated the issue running on Chrome Android Devices. |
Hi, it's been some time now since I filed this PR, so regardless whether it gets accepted or not, I feel like providing a little update for those affected. We've been using a patched idb-keyval with the PR's code in a production Ionic/Capacitor app. It doesn't seems to cause any new problem but I cannot conclude that it actually helps much. That may sound strange but the reasons are the following:
|
We're also seeing this issue on our production app and I just realized about the existence on this PR. Do we know if this going to be merged anytime soon? |
// Meant to be used only in specific tests | ||
export async function closeDatabase(dbName: string) { | ||
if (!databases[dbName]) { | ||
console.assert(true, `Could not find database "${dbName}" to close.`); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could simply console.error
?
@rgomezr391 I'm setting aside time in the next couple of weeks to pick up tickets on this project |
It does not seems to be much activity on this project but here's comes a rather important PR for which hopefully we get feedback.
There (still) seems to be a problem with iOS Safari, where the database connection is unexpectedly closed. This is difficult to reproduce but it appears that it happens when an app has been active in the background for some time and the internet connection has been lost (and then maybe reestablished). It's also unclear whether this is caused by a bug in iOS Safari or the occasional unexpected closure is actually valid - behaving by design.
From what I could see idp-keyval does not seem to have any recovery logic to handle this case. I guess in practice this could mean that the functionality is broken until one kills/restarts the app.
Our error logs are now clogged with "InvalidStateError: Failed to execute 'transaction' on 'IDBDatabase': The database connection is closing." reports and we're not really sure what's the effect of this on around 10% of our users/user sessions.
Same/similar reported issues are:
Failed to execute 'transaction' on 'IDBDatabase': The database connection is closing.
occurs #165I've noticed that projects like Firebase (storage related) and Dexie have already taken measures for database connection recovery.
This PR is sort of a blind attempt to address the issue given the difficulty to reproduce, but we're testing it atm. It doesn't seem to cause any new issues/problems.